# LibreLane Leo Moser HeiChips 2025 # Background: OpenLane - 2020: First open-source Process Design Kit by Skywater: sky130 - Problem: The PDK was free, but there was no compatible end-to-end open-source flow - Solution: OpenLane - Developed by Efabless Corporation - Free & Open-source - o Batteries-included & Easily configurable - Hundreds of designs on the Open MPW shuttles # Problems with OpenLane: The Architecture - Developed on a very strict deadline - lots of architectural shortcuts taken, no proper abstraction - Running parts of the flow (more common than you think) - extremely buggy - No standard way of reporting data about the design - o area, power consumption, clock speed... - Difficult to add custom steps to the flow (integrate other tools) - Tcl "stringly-typed" language # Introducing LibreLane Open-source digital design flow infrastructure #### What is LibreLane? - A ground-up rewrite of OpenLane - Started at Efabless as "OpenLane 2" - (Mostly) backwards-compatible with OpenLane 1 - Fully customizable Python-based Flow - All tools included and ready to download and run: - Natively using a package manager called Nix - Containerized using Docker - In your browser using Colab - Community-driven! - https://matrix.to/#/#librelane:fossi-chat.org https://colab.research.google.com/github/librelane/librelane/blob/main/notebook.ipynb # Technical Design Goals #### Retain the simplicity of OpenLane Ultimately, it is still simple to configure your chip and get from Verilog to GDSII #### Offer robust packaging Not just build-scripts: something that can replicate the environment in various places, and not only using containerization and/or emulation, but natively #### Modularity and API Access - Adheres to a simple object-oriented architecture - While still supporting OpenLane config files using the "Classic" flow, you can very easily implement your own flows #### **Architectural Overview** Performs validation of Encapsulates the state Encapsulates Encapsulates a of the design as an aggregations of steps various variables used configurable for ease of to configure flows and immutable dictionary transformation on the of paths to various configuration and steps, incl. type State object. design formats. ease-of-execution. checking. flow config state step module module module module The LibreLane Python API #### LibreLane: State # State N netlist: design.def Step: OpenROAD.GlobalPlacement Inputs: DEF Outputs: DEF State N+1 netlist: design.def - Each step consumes a state and generates a new state - Each state is explicitly saved as a JSON file - DesignFormat:Mapping from view to file #### The LibreLane Classic Flow - The default flow of LibreLane - Re-implementation of the OpenLane flow using the Python API - Key enhancements: - Improved handling of Macros - MACROS configuration variable listing macro views and instances - Power pins for macros may be declared in RTL with an `ifdef - Parallelized STA, including multi-corner extraction and analysis - Additional DRC with KLayout - Basic SystemVerilog, VHDL support - Better tool warning capture # Simple Example Counter # Simple Example: Counter #### config.yaml ``` DESIGN_NAME: counter VERILOG_FILES: dir::src/*.sv CLOCK_PORT: clk_i CLOCK_PERIOD: 10 # ns ``` #### CLI ``` $ librelane config.yaml ``` #### counter.sv ``` module counter ( input logic clk i, input logic rst_ni, output logic [7:0] count o ); always_ff @(posedge clk i) begin if (!rst ni) begin count o \leftarrow '0; end else begin count o \le count o + 1; end end endmodule ``` # Simple Example: Counter ``` leo@debian-pc: ~/Repositories/librelane-merge + ≡ × [INFO DRT-0036] via3 guide region guery size = 0. [INFO DRT-0036] met4 guide region guery size = 0. [INFO DRT-0036] via4 guide region query size = 0. [INFO DRT-0036] met5 guide region query size = 0. [INFO DRT-0179] Init gr pin query. INFO DRT-02671 cpu time = 00:00:00, elapsed time = 00:00:00, memory = 138.14 (MB), peak = 138.14 (MB) [INFO DRT-0245] skipped writing guide updates to database. [INFO DRT-0185] Post process initialize RPin region query. [INFO DRT-0181] Start track assignment. INFO DRT-01841 Done with 145 vertical wires in 1 frboxes and 87 horizontal wires in 1 [INFO DRT-0186] Done with 15 vertical wires in 1 frboxes and 19 horizontal wires in 1 [INFO DRT-0182] Complete track assignment. [INFO DRT-0267] cpu time = 00:00:00, elapsed time = 00:00:00, memory = 139.19 (MB), peak = 139.19 (MB) [INFO DRT-0187] Start routing data preparation. INFO DRT-02671 cpu time = 00:00:00, elapsed time = 00:00:00, memory = 139.19 (MB), peak = 139.19 (MB) [INFO DRT-0194] Start detail routing. [INFO DRT-0195] Start Oth optimization iteration. Completing 10% with 0 violations. elapsed time = 00:00:00, memory = 144.28 (MB). Completing 20% with 5 violations. elapsed time = 00:00:00, memory = 144.28 (MB). Classic - Stage 47 - Detailed Routing - 46/79 0:00:44 ``` # Officially Supported PDKs - Open source PDKs - $\circ$ sky130 2.0.0 - gf180mcu 2.0.0 - $\circ$ ihp-sg13g2 3.0.0 (upcoming) - IHP Open PDK - Initial LibreLane support merged! - Pre-release in ciel: - https://github.com/fossi-foundation/ciel - Select the PDK - export PDK - o pass "--pdk" as argument # Officially Supported PDKs sky130A gf180mcuD ihp-sg13g2 # Advanced Usage - Customizing Flows - From the config file - From Python - Custom Steps - Plugin system: Extensibility - "Back at Efabless" - DFT plugin - Synopsys plugin - Greyhound - FABulous plugin ### LibreLane Success Stories # Greyhound ihp-sg13g2 https://github.com/mole99/greyhound-ihp # Frigate sky130 #### **Tiny Tapeout** sky130 & ihp-sg13g2 ...and many more # Looking to the Future (Community-driven) - Main development @ AUC Open Hardware Lab - Same primary authors, basically - Legal stewardship of the FOSSi Foundation - Also handling hosting the repositories and binaries - Aim: Community-driven development - Many individuals and companies contributing to and benefitting from the same tool - More PDKs! More plugins! More tools! # Community #### FOSSi Chat - Community for Free and Open Source Silicon - Hosted and administered by the FOSSi Foundation - https://fossi-chat.org #### **Documentation** #### https://librelane.readthedocs.io - Nix and Docker based installation - Usage guides - Full flow, steps and variables documentation - LibreLane API ## Thank you! #### Give us a star on GitHub! github.com/librelane/librelane HeiChips 2025 - LibreLane